

# Compa Family CPLDs Dedicated RAM Module (DRM) User Guide

(UG030002, V1.2) (03.03.2020)

Shenzhen Pango Microsystems Co., Ltd.
All Rights Reserved. Any infringement will be subject to legal action.



# **Revisions History**

# **Document Revisions**

| Version | Date of Release | Revisions        |
|---------|-----------------|------------------|
| V1.2    | 03.03.2020      | Initial release. |
|         |                 |                  |

(UG030002, V1.2) 1/28



# **About this Manual**

# **Terms and Abbreviations**

| Terms and Abbreviations | Meaning              |
|-------------------------|----------------------|
| DRM                     | Dedicated RAM Module |
| DP                      | Dual Port            |
| SDP                     | Simple Dual Port     |
| SP                      | Single Port          |
| NW                      | Normal Write         |
| RBW                     | Read before Write    |
| TW                      | Transparent Write    |
| BW                      | Byte Write           |
| OR                      | Output Register      |
| IPC                     | IP Compiler          |
|                         |                      |

(UG030002, V1.2) 2 / 28



# **Table of Contents**

| Revisions History                            | 1  |
|----------------------------------------------|----|
| About this Manual                            | 2  |
| Table of Contents                            | 3  |
| Tables                                       | 5  |
| Figures                                      | 6  |
| Chapter 1 Overview                           | 7  |
| 1.1 Features                                 | 7  |
| 1.2 Supported Configurations                 | 8  |
| 1.2.1 DPRAM Mode                             | 8  |
| 1.2.2 SDPRAM Mode                            | 9  |
| 1.2.3 SPRAM Mode and ROM Mode                | 9  |
| 1.2.4 Data Width                             | 9  |
| 1.2.5 Usage Rules for Compa Family CPLDs DRM | 10 |
| 1.2.6 DRM Simulation Model                   | 10 |
| Chapter 2 DRM                                | 11 |
| 2.1 Ports and Description                    | 11 |
| 2.2 Memory Model                             |    |
| 2.2.1 DPRAM Mode                             |    |
| 2.2.2 SDPRAM Mode                            |    |
| 2.2.3 SPRAM Mode and ROM Mode                |    |
| 2.3 Write Operation Mode                     |    |
| 2.3.1 NW Mode                                |    |
| 2.3.2 TW Mode                                |    |
| 2.3.3 RBW Mode                               |    |
| 2.3.4 Byte Write Mode                        |    |
| 2.4 Output Register Mode                     | 20 |
| 2.5 Synchronous and Asynchronous Reset       | 21 |
| 2.6 Mixed Bit Width Function                 | 21 |
| 2.7 DRM Cascade Expansion Function           | 22 |
| Chapter 3 DRM FIFO Mode                      | 23 |
| 3.1 DRM FIFO Mode Ports and Descriptions     | 23 |
| 3.2 DRM_FIFO Read/Write Timing               | 25 |
| 3.2.1 Write Timing to Empty FIFO             | 25 |
| 3.2.2 Write Timing to Almost Full FIFO       | 25 |
| 3.2.3 Read Timing from Full FIFO             | 25 |
| 3.2.4 Read Timing from Almost Empty FIFO     | 26 |



| 3.3 DRM FIFO Cascade Expansion               | 26 |
|----------------------------------------------|----|
| 3.3.1 Recommended Method for Depth Expansion | 26 |
| 3.3.2 Recommended Method for Width Expansion | 27 |
| Disclaimer                                   | 28 |

(UG030002, V1.2) 4/28



# **Tables**

| Table 1-1 Function Overview List                                                           | 7  |
|--------------------------------------------------------------------------------------------|----|
| Table 1-2 Allowed Bit Width Combinations for DPRAM Mode                                    | 8  |
| Table 1-3 Allowed Bit Width Combinations for SDPRAM Mode                                   | 9  |
| Table 1-4 Allowed Bit Width Combinations for SPRAM Mode and ROM Mode                       | 9  |
| Table 1-5 Table Address and Data Port Mapping Corresponding to DRM Memory Mode             | 9  |
| Table 1-6 Data Address Mapping for Different Data Widths (x1, x2, x4, x8, x16 data widths) | 10 |
| Table 1-7 Data Address Mapping for Different Data Widths (x9 and x18 data widths)          | 10 |
| Table 1-8 Compa Family CPLDs DRM Primitives                                                | 10 |
| Table 2-1 DRM Configuration Parameters                                                     | 11 |
| Table 2-2 DRM Port Naming and Description                                                  | 12 |
| Table 2-3 List of Additional Information Bit for Bytes                                     | 13 |
| Table 2-4 DP RAM Port Naming and Description                                               | 14 |
| Table 2-5 SDPRAM Port Naming and Description                                               | 15 |
| Table 2-6 SPRAM Mode Port Naming and Description                                           | 16 |
| Table 2-7 ROM Mode Port Naming and Description                                             | 17 |
| Table 2-8 Byte Enable Signal Control                                                       | 20 |
| Table 2-9 DOA/B Output List when Resetting/Setting                                         | 21 |
| Table 3-1 Asynchronous/Synchronous FIFO Mode Data Width List                               | 23 |
| Table 3-2 DRM_FIFO Parameter List                                                          | 23 |
| Table 3-3 DRM FIFO Mode Port Description                                                   | 24 |



# **Figures**

| Figure 2-1 DRM Data Ports                                                | 11 |
|--------------------------------------------------------------------------|----|
| Figure 2-2 DP RAM Data Ports                                             | 14 |
| Figure 2-3 SDPRAM Data Ports                                             | 15 |
| Figure 2-4 SPRAM Mode                                                    | 16 |
| Figure 2-5 ROM Mode                                                      | 17 |
| Figure 2-6 Address Line Configuration for TW and RBW Modes in SPRAM Mode | 18 |
| Figure 2-7 Output Timing Diagram for the Three Writing Operation Modes   | 18 |
| Figure 2-8 Read-Write Timing Diagram for NW Mode                         | 19 |
| Figure 2-9 Read-Write Timing Diagram for TW Mode                         | 19 |
| Figure 2-10 Read-Write Timing Diagram for RBW Mode                       | 20 |
| Figure 2-11 Read Timing Diagram with Output Register                     | 21 |
| Figure 3-1 DRM FIFO Mode Ports                                           | 23 |
| Figure 3-2 Writing Timing to Empty Asynchronous FIFO                     | 25 |
| Figure 3-3 Write Timing to Almost Full FIFO                              | 25 |
| Figure 3-4 Read Timing from Full Asynchronous FIFO                       | 26 |
| Figure 3-5 Read Timing from Almost Empty FIFO                            | 26 |
| Figure 3-6 Recommended Method for Depth Expansion                        | 27 |
| Figure 3-7 Recommended Method for Width Expansion                        | 27 |



## **Chapter 1 Overview**

The DRM of the Compa Family CPLDs has storage units of up to 9K bits, and two adjacent DRMs can be combined into one 16Kx1 memory without the need for additional external logic. Each DRM supports DP (True Dual Port) RAM mode, and can also be configured as SP (Single Port) RAM mode, SDP (Simple Dual Port) RAM mode, ROM mode, as well as synchronous/asynchronous FIFO mode. DRM resources also support Input Register (IR) and Output Register (OR), allowing superior performance when DRMs are cascaded. The total number of DRMs depends on the type of Compa Family device.

The port data width of DP RAM mode goes up to 9 bits, with its two ports being completely independent apart from sharing RAM content, and supporting different clock domains; the port data width of SDPRAM goes up to 18 bits, with its two ports also supporting different clock domains, but one port is limited to write operations and the other is limited to read operations. In ROM mode, the port data width of the ROM can be up to 18 bits. The content of the DRM is typically initialized during the process of downloading FPGA's configuration data. Of course, the content of the DRM can also be initialized using FPGA's programmed configurations in other modes. In synchronous or asynchronous FIFO mode, one port is dedicated to FIFO data writing, and the other port is dedicated to FIFO data reading; read and write ports can support different clocks, but do not support mixed bit widths or byte enable write operations. Two adjacent DRMs can be combined into one 16Kx1 memory without the need for additional external logic. The DRM function overview list is shown in Table 1-1.

DPRAM, SPRAM, SDPRAM, ROM, and synchronous/asynchronous FIFO modules can be conveniently generated through the IP Compiler tool embedded in the Pango Design Suite software by Shenzhen Pango Microsystems Co., Ltd.

#### 1.1 Features

The DRM function overview list for the Compa Family CPLDs is shown in Table 1-1.

Table 1-1 Function Overview List

| <b>Function Overview List</b> |                                                           |
|-------------------------------|-----------------------------------------------------------|
| Memory Capacity               | 9Kbits                                                    |
| Configurable Mode             | Dual-port, simple dual-port, single-port, ROM, FIFO modes |
| DDM Configuration             | Dual-port: 8Kx1/4Kx2/2Kx4/1Kx8/1Kx9                       |
| DRM Configuration             | Simple dual-port: 8Kx1/4Kx2/2Kx4/1Kx8/512x16/1Kx9/512x18  |

(UG030002, V1.2) 7/28



| <b>Function Overview</b>                                                                         | List                                                                                           |  |  |  |
|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--|--|--|
|                                                                                                  | Single-port: 8Kx1/4Kx2/2Kx4/1Kx8/512x16/1Kx9/512x18                                            |  |  |  |
|                                                                                                  | FIFO: 8Kx1/4Kx2/2Kx4/1Kx8/512x16/1Kx9/512x18                                                   |  |  |  |
|                                                                                                  | Normal Write mode supported                                                                    |  |  |  |
| Write Mode                                                                                       | Transparent Write mode supported                                                               |  |  |  |
|                                                                                                  | Read-Before Write mode supported                                                               |  |  |  |
|                                                                                                  | Synchronous reset supported                                                                    |  |  |  |
| Reset Mode                                                                                       | Asynchronous reset supported                                                                   |  |  |  |
|                                                                                                  | Independent reset of A/B ports supported                                                       |  |  |  |
| Output clock inversion                                                                           | on supported                                                                                   |  |  |  |
| Configurable output                                                                              | registers during reset/set supported                                                           |  |  |  |
| Configurable address                                                                             | s hold supported                                                                               |  |  |  |
| Configurable output                                                                              | register supported                                                                             |  |  |  |
| Independent configur                                                                             | ration of bit widths for ports A and B of dual-port supported                                  |  |  |  |
| Byte write enable sup                                                                            | pported                                                                                        |  |  |  |
| Input register suppor                                                                            | ted                                                                                            |  |  |  |
| Read and write opera<br>enabled)                                                                 | ations require only one clock cycle (two clock cycles are required when the output register is |  |  |  |
| Combining two adjacent DRMs into one 16Kx1 memory without additional external logic is supported |                                                                                                |  |  |  |
| Read/write pointer or                                                                            | utput in FIFO mode supported                                                                   |  |  |  |

## 1.2 Supported Configurations

#### 1.2.1 DPRAM Mode

In DPRAM mode, DRM has a maximum data width of 9 bits, the bit widths of the two ports can be independently configured according to DRM resources. In the DRM module, both A and B ports can independently perform read and write operations, each supporting an independent clock. The allowed bit width combinations for DPRAM mode are shown in Table 1-2.

Table 1-2 Allowed Bit Width Combinations for DPRAM Mode

|        |      |      | Port B |      |      |      |  |  |
|--------|------|------|--------|------|------|------|--|--|
|        |      | 8Kx1 | 4Kx2   | 2Kx4 | 1Kx8 | 1Kx9 |  |  |
|        | 8Kx1 | √    | V      | V    | 1    |      |  |  |
|        | 4Kx2 | √    | √      | √    | √    |      |  |  |
| Port A | 2Kx4 | √    | √      | √    | √    |      |  |  |
|        | 1Kx8 | √    | √      | √    | √    |      |  |  |
|        | 1Kx9 |      |        |      |      | √    |  |  |

(UG030002, V1.2) 8 / 28



#### 1.2.2 SDPRAM Mode

In SDPRAM mode, the DRM data width increases to 18 bits, with one port dedicated to data writing and the other for data reading, both read and write ports also support different clocks. The allowed bit width combinations for SDPRAM mode are shown in Table 1-3.

**Write Port** 4Kx2 2Kx4 1Kx8 512x16 8Kx1 1Kx9 512x18 8Kx14Kx2  $\sqrt{}$  $\sqrt{}$  $\checkmark$  $\sqrt{}$  $\sqrt{}$ 2Kx4  $\checkmark$  $\checkmark$  $\checkmark$ √  $\checkmark$  $\checkmark$  $\checkmark$ Read Port 1Kx8  $\checkmark$  $\checkmark$  $\checkmark$  $\sqrt{}$ 512x16 1Kx9 512x18

Table 1-3 Allowed Bit Width Combinations for SDPRAM Mode

#### 1.2.3 SPRAM Mode and ROM Mode

The allowed bit width combinations for SPRAM mode and ROM mode are shown in Table 1-4.

Table 1-4 Allowed Bit Width Combinations for SPRAM Mode and ROM Mode

|      |        | 8Kx1         | 4Kx2         | 2Kx4         | 1Kx8      | 512x16       | 1Kx9      | 512x18       |
|------|--------|--------------|--------------|--------------|-----------|--------------|-----------|--------------|
| Mode | SP RAM | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\sqrt{}$ | $\sqrt{}$    | $\sqrt{}$ | $\checkmark$ |
| Mode | ROM    | $\sqrt{}$    | $\sqrt{}$    | $\sqrt{}$    | $\sqrt{}$ | $\checkmark$ | $\sqrt{}$ | $\checkmark$ |

#### 1.2.4 Data Width

In DRM memory mode, the corresponding address and data port mapping can be seen in Table 1-5, and the data address mapping for different bit widths can be seen in Table 1-6 and Table 1-7.

Table 1-5 Table Address and Data Port Mapping Corresponding to DRM Memory Mode

| DRM Port<br>Mode | Address and Data Port Mapping |                   |                   |                   |                    |                    |  |  |
|------------------|-------------------------------|-------------------|-------------------|-------------------|--------------------|--------------------|--|--|
|                  | Port A<br>Address             | Port B<br>Address | Port A data input | Port B data input | Port A data output | Port B data output |  |  |
| 8K*1             | ADDRA<br>[12:0]               | ADDRB<br>[12:0]   | DIA [0]           | DIB [0]           | DOA [0]            | DOB [0]            |  |  |
| 4K*2             | ADDRA<br>[12:1]               | ADDRB<br>[12:1]   | DIA [1:0]         | DIB [1:0]         | DOA [1:0]          | DOB [1:0]          |  |  |
| 2K*4             | ADDRA<br>[12:2]               | ADDRB<br>[12:2]   | DIA [3:0]         | DIB [3:0]         | DOA [3:0]          | DOB [3:0]          |  |  |
| 1K*8             | ADDRA<br>[12:3]               | ADDRB<br>[12:3]   | DIA [7:0]         | DIB [7:0]         | DOA [7:0]          | DOB [7:0]          |  |  |
| 1K*9             | ADDRA<br>[12:3]               | ADDRB<br>[12:3]   | DIA [8:0]         | DIB [8:0]         | DOA [8:0]          | DOB [8:0]          |  |  |

(UG030002, V1.2) 9 / 28



| DRM Port | Address and Data Port Mapping |                   |                     |                   |                    |                          |  |
|----------|-------------------------------|-------------------|---------------------|-------------------|--------------------|--------------------------|--|
| Mode     | Port A<br>Address             | Port B<br>Address | Port A data input   | Port B data input | Port A data output | Port B data output       |  |
| 512*16   | ADDRA<br>[12:4]               | ADDRB<br>[12:4]   | {DIB[7:0],DIA[7:0]} | N/A               | N/A                | {DOB[7:0],DO<br>A [7:0]} |  |
| 512*18   | ADDRA<br>[12:4]               | ADDRB<br>[12:4]   | {DIB[8:0],DIA 8:0]} | N/A               | N/A                | {DOB[8:0],DO<br>A [8:0]} |  |

Table 1-6 Data Address Mapping for Different Data Widths (x1, x2, x4, x8, x16 data widths)

| Data Width |    | Lowest-bit port address<br>(compared with the least-bit port address in the maximum data width mode) |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|------------|----|------------------------------------------------------------------------------------------------------|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 16         |    | 0                                                                                                    |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
| 8          |    | 1 0                                                                                                  |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
| 4          |    | 3 2 1 0                                                                                              |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
| 2          | 7  |                                                                                                      | (  | 5  | 5 4 |    | 3 | 3 | 2 | 2 | - | 1 | ( | ) |   |   |
| 1          | 15 | 14                                                                                                   | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Table 1-7 Data Address Mapping for Different Data Widths (x9 and x18 data widths)

| Data Width | Lowest-bit port address (compared with the least-bit port address in the maximum data width mode) |   |  |  |  |  |
|------------|---------------------------------------------------------------------------------------------------|---|--|--|--|--|
| 18         | 0                                                                                                 | 0 |  |  |  |  |
| 9          | 1                                                                                                 | 0 |  |  |  |  |

#### 1.2.5 Usage Rules for Compa Family CPLDs DRM

In DPRAM and SDP RAM modes, there are two relatively independent ports, and performing a read and a write operation on the same address through both ports simultaneously will cause a collision. He conflicts between two ports simultaneously writing data to the same address and performing a read or a write on the same address are illegal operations in DRM, and the current operation cannot be completed normally, so users need to avoid them logically in actual applications.

#### 1.2.6 DRM Simulation Model

The simulation model for the Compa Family CPLDs DRM is GTP\_DRM9K\_E1, and the simulation model for FIFO is GTP\_FIFO9K, and their supported types are shown in Table 1-8:

Table 1-8 Compa Family CPLDs DRM Primitives

| Simulation Model | Supported Mode                                           |
|------------------|----------------------------------------------------------|
| GTP_DRM9K_E1     | Supports bit widths of x1, x2, x4, x8, x16 (and x9, x18) |
| GTP_FIFO9K       | Supports bit widths of x1, x2, x4, x8, x16 (and x9, x18) |

Note: All simulation models can be found in the software installation path, e.g., C:\Pango\PDS\arch\vendor\pango\verilog\simulation.

(UG030002, V1.2)



# **Chapter 2 DRM**

## 2.1 Ports and Description

DRM data ports are shown in Figure 2-1, DRM configuration parameters are shown in Table 2-1, and DRM port names and descriptions are shown in Table 2-2.



Figure 2-1 DRM Data Ports

Table 2-1 DRM Configuration Parameters

| Parameter                      | Description                             | Setting Value                                                        |  |  |
|--------------------------------|-----------------------------------------|----------------------------------------------------------------------|--|--|
| CSA_MASK[2:0]                  | Port A address extension control signal | 0 ~ 7                                                                |  |  |
| CSB_MASK[2:0]                  | Port B address extension control signal | 0 ~ 7                                                                |  |  |
| DATA_WIDTH_A                   | Data width of Port A                    | 1, 2, 4, 8, 16, 9, 18                                                |  |  |
| DATA_WIDTH_B                   | Data width of Port B                    | 1, 2, 4, 8, 16, 9, 18                                                |  |  |
| WRITE_MODE_A Port A write mode |                                         | NORMAL_WRITE<br>TRANSPARENT_WRITE<br>READ_BEFORE_WRITE               |  |  |
| WRITE_MODE_B                   | Port B write mode                       | NORMAL_WRITE TRANSPARENT_WRITE READ_BEFORE_WRITE                     |  |  |
| DOA_REG                        | Port A output register                  | 0 = Do not enable output register<br>1 = Enable output register      |  |  |
| DOB_REG                        | Port B output register                  | 0 = Do not enable output register<br>1 = Enable output register      |  |  |
| RST_TYPE Reset mode selection  |                                         | SYNC: Synchronous reset ASYNC: Asynchronous reset                    |  |  |
| RAM_MODE RAM mode selection    |                                         | TRUE_DUAL_PORT: Dual-port RAM SIMPLE_DUAL_PORT: Simple dual-port RAM |  |  |

(UG030002, V1.2)



| Parameter      | Description                   | Setting Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|----------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                |                               | SINGLE_PORT: Single-port RAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                |                               | ROM: ROM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|                |                               | NONE: No hard cascade                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                |                               | UPPER: Serves as a hard cascade data output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| RAM_CASCADE    | 16Kx1 hard cascade mode       | module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                |                               | LOWER: Serves as a hard cascade additional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|                |                               | module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| GRS_EN         | Global reset enable signal    | FALSE: Global Reset not enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| GRS_EN         | (Internal Chip)               | TRUE: Global Reset enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| DOA_REG_CLKINV | Port A output register clock  | 0 = Clock not inverted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| DOA_REG_CLRINV | inversion                     | 1 = Clock inverted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| DOD DEC CLVINV | Port B output register clock  | 0 = Clock not inverted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| DOB_REG_CLKINV | inversion                     | 1 = Clock inverted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| DCTA VAI       | Port A output reset/set       | 0 = Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| RSTA_VAL       | Port A output reset/set       | $1 = \mathbf{Set}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| DCTD VAI       | Dont D. outmut reget/get      | 0 = Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| RSTB_VAL       | Port B output reset/set       | $1 = \mathbf{Set}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| INIT_00        |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| INIT_01        | RAM Initialization            | 0 ~2^288-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| INIT_02        | Configuration Parameters      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                | Configuration rarameters      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| INIT_1F        |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                |                               | "NONE": No initialization file is specified, the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|                |                               | default initialization data will be the value set by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| INIT_FILE      | Initialization files          | the parameter INIT_00~INIT_1F;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                |                               | "XXX": XXX represents the specific initialization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                |                               | file path                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| BLOCK_X        | Data cascade coordinates when | Depends on the number of cascaded DRMs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 220011_11      | RAM is cascaded               | Department of the first of the |  |  |
| BLOCK_Y        | Address cascade coordinates   | Depends on the number of cascaded DRMs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 220011_1       | when RAM is cascaded          | Depends on the named of caseaded Ditters                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| RAM_DATA_WIDTH | Maximum data width after RAM  | Depends on the number of cascaded DRMs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                | is cascaded                   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| RAM_ADDR_WIDTH | Maximum address width after   | Depends on the number of cascaded DRMs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                | RAM is cascaded               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| INIT_FORMAT    | Initialization file format    | "BIN": Binary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| _              |                               | "HEX": Hexadecimal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |

Table 2-2 DRM Port Naming and Description

| <b>Port Naming</b> | Valid Bit Width | Active Level            | Direction | Description                   |
|--------------------|-----------------|-------------------------|-----------|-------------------------------|
| DIA                | [8:0]           |                         | Input     | Port A data input bus         |
| ADDRA              | [13:0]          |                         | Input     | Port A address input bus      |
| WEA                | 1               | 1 for write, 0 for read | Input     | Port A write enable           |
| CEA                | 1               | Active-high             | Input     | Port A clock enable           |
| CLKA               | 1               |                         | Input     | Port A clock                  |
| RSTA               | 1               | Active-high             | Input     | Port A output register reset  |
| CSA                | [2:0]           |                         | Input     | Port A address extension      |
| ORCEA              | 1               | Active-high             | Input     | Port A output register enable |
| DOA                | [8:0]           |                         | Output    | Port A data output bus        |
| CINA               | 1               |                         | Input     | Port A cascade input          |

(UG030002, V1.2) 12 / 28



| <b>Port Naming</b> | Valid Bit Width | Active Level            | Direction | Description                   |
|--------------------|-----------------|-------------------------|-----------|-------------------------------|
| COUTA              | 1               |                         | Output    | Port A cascade output         |
| BWEA               | [1:0]           |                         | I         | Port A bytes write enable     |
| DIB                | [8:0]           |                         | I         | Port B data input bus         |
| ADDRB              | [13:0]          |                         | I         | Port B address input bus      |
| WEB                | 1               | 1 for write, 0 for read | I         | Port B write enable           |
| CEB                | 1               | Active-high             | I         | Port B clock enable           |
| CLKB               | 1               |                         | I         | Port B clock                  |
| RSTB               | 1               | Active-high             | I         | Port B output register reset  |
| CSB                | [2:0]           |                         | I         | Port B address extension      |
| ORCEB              | 1               | Active-high             | I         | Port B output register enable |
| DOB                | [8:0]           |                         | Output    | Port B data output bus        |
| CINB               | 1               |                         | I         | Port B cascade input          |
| COUTB              | 1               |                         | Output    | Port B cascade output         |

In x9 and x18 data width modes, there is one additional information storage bit per byte, as shown in Table 2-3:

Table 2-3 List of Additional Information Bit for Bytes

|              | Port A data input bus |                                  | Port B data input bus |                                  | Port A data output bus |                                  | Port B data output bus |                                  |
|--------------|-----------------------|----------------------------------|-----------------------|----------------------------------|------------------------|----------------------------------|------------------------|----------------------------------|
| Port<br>Mode | Byte                  | Additional<br>Information<br>Bit | Byte                  | Additional<br>Information<br>Bit | Byte                   | Additional<br>Information<br>Bit | Byte                   | Additional<br>Information<br>Bit |
| 1K*9         | DIA[7:<br>0]          | DIA[8]                           | DIB[7: 0]             | DIB[8]                           | DOA<br>[7:0]           | DOA[8]                           | DOB<br>[7:0]           | DOB[8]                           |
| 512*         | DIA[1<br>6:9]         | DIA[17]                          | DIB<br>[16:9]         | DIB[17]                          | DOA<br>[16:9]          | DOA[17]                          | DOB<br>[16:9]          | DOB[17]                          |
| 18           | DIA[7: 0]             | DIA[8]                           | DIB[7: 0]             | DIB[8]                           | DOA<br>[7:0]           | DOA[8]                           | DOB<br>[7:0]           | DOB[8]                           |

#### 2.2 Memory Model

#### 2.2.1 DPRAM Mode

The DPRAM mode has two independent ports, A and B, besides the ports that share DRM content. Their structures are completely symmetrical, as shown in Figure 2-2. The port names and descriptions are shown in Table 2-4.

(UG030002, V1.2) 13 / 28





Figure 2-2 DP RAM Data Ports

Table 2-4 DP RAM Port Naming and Description

| Port Naming | GTP Mapping<br>Relationships | Valid Bit<br>Width | Active Level            | Direction | Description                   |
|-------------|------------------------------|--------------------|-------------------------|-----------|-------------------------------|
| DA          | DIA                          | [8:0]              |                         | Input     | Port A data input bus         |
| ADA         | ADDRA                        | [13:0]             |                         | Input     | Port A address input bus      |
| WEA         | WEA                          | 1                  | 1 for write, 0 for read | Input     | Port A write enable           |
| CEA         | CEA                          | 1                  | Active-high             | Input     | Port A clock enable           |
| CLKA        | CLKA                         | 1                  |                         | Input     | Port A clock                  |
| RSTA        | RSTA                         | 1                  | Active-high             | Input     | Port A output register reset  |
| CSA         | CSA                          | [2:0]              |                         | Input     | Port A address extension      |
| OCEA        | ORCEA                        | 1                  | Active-high             | Input     | Port A output register enable |
| QA          | DOA                          | [8:0]              |                         | Output    | Port A data output bus        |
| DB          | DIB                          | [8:0]              |                         | Input     | Port B data input bus         |
| ADB         | ADDRB                        | [13:0]             |                         | Input     | Port B address input bus      |
| WEB         | WEB                          | 1                  | 1 for write, 0 for read | Input     | Port B write enable           |
| CEB         | CEB                          | 1                  | Active-high             | Input     | Port B clock enable           |
| CLKB        | CLKB                         | 1                  |                         | Input     | Port B clock                  |
| RSTB        | RSTB                         | 1                  | Active-high             | Input     | Port B output register reset  |
| CSB         | CSB                          | [2:0]              |                         | Input     | Port B address extension      |
| OCEB        | ORCEB                        | 1                  | Active-high             | Input     | Port B output register enable |
| QB          | DOB                          | [8:0]              |                         | Output    | Port B data output bus        |

#### 2.2.2 SDPRAM Mode

Each DRM can also be configured as SDPRAM. In this mode, the DRM port data width is

(UG030002, V1.2) 14/28



increased to 18 bits, with port A dedicated to data writing and port B to data reading, and both reading and writing ports support different clocks. The supported combination modes for SDPRAM are shown in Table 1-6 and Table 1-7, the SDPRAM data port descriptions are shown in Figure 2-3, and port names and descriptions are shown in Table 2-5.



Figure 2-3 SDPRAM Data Ports

Table 2-5 SDPRAM Port Naming and Description

| Port Naming | GTP Mapping<br>Relationships | Valid Bit<br>Width | Active Level | Direction | Description               |
|-------------|------------------------------|--------------------|--------------|-----------|---------------------------|
| WD          | DIA                          | [8:0]              |              | Input     | Data input bus            |
| WAD         | ADDRA                        | [13:0]             |              | Input     | Write address input bus   |
| WE          | WEA                          | 1                  | Active-high  | Input     | Write enable              |
| WCE         | CEA                          | 1                  | Active-high  | Input     | Write clock enable        |
| WCLK        | CLKA                         | 1                  |              | Input     | Write clock               |
| WRST        | RSTA                         | 1                  | Active-high  | Input     | Write register reset      |
| WCS         | CSA                          | [2:0]              |              | Input     | Write address extension   |
| WBE         | BWEA                         | [1:0]              |              | Input     | Write byte enable control |
| Q           | DOB                          | [8:0]              |              | Output    | Data output bus           |
| RAD         | ADDRB                        | [13:0]             |              | Input     | Read address input bus    |
| ROCE        | ORCEB                        | 1                  | Active-high  | Input     | Output register enable    |
| RCE         | CEB                          | 1                  | Active-high  | Input     | Read clock enable         |
| RCLK        | CLKB                         | 1                  |              | Input     | Read clock                |
| RRST        | RSTB                         | 1                  | Active-high  | Input     | Read register reset       |
| RCS         | CSB                          | [2:0]              |              | Input     | Read address extension    |

#### 2.2.3 SPRAM Mode and ROM Mode

#### 2.2.3.1 SPRAM Mode Data Ports

In SPRAM mode, DRM contains two ports, and SPRAM mode allows independent read and write operations on these two ports.

(UG030002, V1.2) 15 / 28

Data output bus

Output



The data flow of SPRAM is explained in Figure 2-4, Table 2-6 and port names and port descriptions are listed in.



Figure 2-4 SPRAM Mode

**GTP Mapping** Valid Bit **Port Naming Active Level** Direction Description Relationships Width D DIA [8:0]Data input bus Input **ADDRA** AD [13:0] Input Address input bus WE **WEA** 1 Active-high Input Write enable 1 CE **CEA** Active-high Write clock enable Input CLK 1 **CLKA** Input Write clock **RST RSTA** 1 Active-high Input Write register reset CS **CSA** Address extension [2:0]Input OCE **ORCEA** 1 Active-high Output register enable Input

Table 2-6 SPRAM Mode Port Naming and Description

#### 2.2.3.2 ROM Mode Data Ports

DOA

Q

The DRM can be configured as ROM, with ROM contents initialized through the configuration interface. ROM mode only has read ports.

[8:0]

The data flow of ROM is explained in Figure 2-5, and port names and port descriptions are listed in Table 2-7.

(UG030002, V1.2) 16 / 28





Figure 2-5 ROM Mode

Table 2-7 ROM Mode Port Naming and Description

| Port Naming | GTP Mapping<br>Relationships | Valid Bit<br>Width | Active Level | Direction | Description            |
|-------------|------------------------------|--------------------|--------------|-----------|------------------------|
| AD          | ADDRA                        | [13:0]             |              | Input     | Read address input     |
| CE          | CEA                          | 1                  | Active-high  | Input     | Read clock enable      |
| CLK         | CLKA                         | 1                  |              | Input     | Read clock             |
| RST         | RSTA                         | 1                  | Active-high  | Input     | Read register reset    |
| CS          | CSA                          | [2:0]              |              | Input     | Address extension      |
| OCE         | ORCEA                        | 1                  | Active-high  | Input     | Output register enable |
| Q           | DOA                          | [8:0]              |              | Output    | Data output bus        |

#### 2.2.3.3 Implementation Descriptions for TW and RBW in SPRAM (x16/x18) Mode

DRM cannot enable TW and RBW modes in 16/18 bits SPRAM mode through direct configuration; additional configurations are required, as detailed below:

- 1. Port A and Port B are both configured as 8/9 bits DPRAM mode (for 16/18 bits SPRAM, respectively);
- 2. Port A and Port B are configured to the same write mode; other configuration bits also need to be the same.
- 3. The CE, CS, WE, ADDR, ORCE, RST, CLK, and other control signals for Port A are paralleled with the corresponding signals for Port B, meaning they are connected to the same signals for both ports;
- 4. Splicing DIA and DIB as data inputs; splicing DOA and DOB as data outputs;

(UG030002, V1.2) 17 / 28



5. Both Port A and Port B address input ports must be connected to the address input simultaneously; ADDRA[3] and ADDRB[3] must be connected to 0 or 1 respectively (in opposite), as shown in Figure 2-6:



Figure 2-6 Address Line Configuration for TW and RBW Modes in SPRAM Mode

#### 2.3 Write Operation Mode

Depending on the data output from the same port during data writing, the port write operations of DRM support three modes: NW, TW, and RBW. The timing diagram for the three write operation modes is shown in Figure 2-7.



Figure 2-7 Output Timing Diagram for the Three Writing Operation Modes

**Notes:** The port write operating mode of DRM is only applicable to ports with read/write functions, i.e., the A/B ports of DP RAM and the ports of SP RAM.

(UG030002, V1.2)



#### 2.3.1 NW Mode

The read-write timing diagram for the NW mode is shown in Figure 2-8; when a user writes data to a port of the DRM, the output data of that port is not updated at this time. The NW mode is the default mode.



Figure 2-8 Read-Write Timing Diagram for NW Mode

#### 2.3.2 TW Mode

The TW mode read-write timing diagram is shown in Figure 2-9, when a user writes data to a port of the DRM, the written data is directly output to the output port at the same time as it is written to the RAM (i.e., the next clock cycle of the write operation).



Figure 2-9 Read-Write Timing Diagram for TW Mode

#### **2.3.3 RBW Mode**

As the output timing diagram for the three write operation modes shown in Figure 2-7 or the

(UG030002, V1.2) 19 / 28



read-write timing diagram for the RBW mode shown in Figure 2-10, when a user writes data to a port of the DRM, the original data at that address is first read and then output to the output port in the next clock cycle of the write operation.



Figure 2-10 Read-Write Timing Diagram for RBW Mode

#### 2.3.4 Byte Write Mode

DRM supports byte enable for write operations, which writes to selected data bytes through the BWEA signals (active-high) while masking the writing to other bytes at the same address index. When the port width is  $2^N$  bits, only byte enable for 16-bit write operations is supported, with each byte containing 8 bits. When the port width is  $9 \times 2^N$  bits, only byte enable for 18-bit write operations is supported, with each byte containing 9 bits.

Table 2-8 lists the control of the written data bits by the byte enable signal.

| DRM Data Bus Width Byte Width |         | Byte Enable Signal | Actual Data Bit Written |  |
|-------------------------------|---------|--------------------|-------------------------|--|
|                               | 18 bits | BWEA [1:0]=2'b11   | DIA [17:0]              |  |
| 18 bits                       | 0.1-14- | BWEA [1:0]=2'b01   | DIA [8:0]               |  |
|                               | 9 bits  | BWEA [1:0]=2'b10   | DIA [17:9]              |  |

Table 2-8 Byte Enable Signal Control

Note: The BW write operation mode supports x18 (x16) data port width.

#### 2.4 Output Register Mode

For data output ports, DRM provides an optional Output Register for improved timing performance. As shown in Figure 2-11, the output register can be controlled by an independent enable signal ORCE. When ORCE is a constant 1, the use of the output register will increase the delay of the read operation from one clock cycle to two clock cycles (Case 1); in pipeline designs with flow control,

(UG030002, V1.2) 20 / 28

{SC\_SRVAL\_B,SC\_

{SC\_SRVAL\_B,SC\_

SRVAL\_A}

SRVAL\_A}



the user can also flexibly control OCE with logic (Case 2).



Note: The timing diagram of the output register in SDPRAM mode provided in this figure is applicable to other modes

Figure 2-11 Read Timing Diagram with Output Register

#### 2.5 Synchronous and Asynchronous Reset

The DOA/DOB output list when resetting/setting is shown in Table 2-9.

**OR Bypass OR Enable DATA WIDTH** DOA DOB **DOA** DOB {8'b0,SC\_SRVAL\_A[0]} {8'b0,SC\_SRVAL\_B[0]} SC\_SRVAL\_A SC\_SRVAL\_B x1x2{7'b0,SC\_SRVAL\_A[1:0]} {7'b0,SC\_SRVAL\_B[1:0]} SC SRVAL A SC\_SRVAL\_B x4 {5'b0,SC\_SRVAL\_A[3:0]} {5'b0,SC\_SRVAL\_B[3:0]}  $SC\_SRVAL\_A$ SC\_SRVAL\_B x8 SC\_SRVAL\_A SC\_SRVAL\_B SC\_SRVAL\_A SC\_SRVAL\_B x9 SC SRVAL B SC SRVAL A SC SRVAL B SC\_SRVAL\_A

{SC\_SRVAL\_B,SC\_SRVA

{SC\_SRVAL\_B,SC\_SRVA

 $L_A$ 

 $L_A$ 

N/A

N/A

Table 2-9 DOA/B Output List when Resetting/Setting

#### 2.6 Mixed Bit Width Function

N/A

N/A

x16

x18

The port of DRM supports two types of data widths: one is  $2^N$  (including 1/2/4/8/16 bit). The other is  $9 \times 2^N$  (including 9/18 bit).

DPRAM and SDPRAM modes support mixed width, meaning the two ports can be configured with different widths. For example, an SDPRAM can be configured to 8Kx1 at the write port and 512x16 at the read port, thereby saving the serial-to-parallel conversion logic from 1 bit to 16 bits. Please refer to Table 1-5, Table 1-6, and Table 1-7.

(UG030002, V1.2) 21 / 28



## **2.7 DRM Cascade Expansion Function**

Multiple DRMs can be combined into larger DPRAMs, SDPRAMs, SPRAMs, or ROMs through cascade expansion. For this, DRM provides an additional 3-bit address extension (CS[2:0]), commonly used for deeply-extended applications.

In x1 width mode, two adjacent DRMs can be combined into a 16Kx1 via hard cascading, and support 16Kx1 single-port RAM, 16Kx1 dual-port RAM, 16Kx1 simple dual-port RAM, and 16Kx1 ROM.

(UG030002, V1.2) 22 / 28



# **Chapter 3 DRM FIFO Mode**

## 3.1 DRM FIFO Mode Ports and Descriptions

The ports and descriptions for DRM FIFO mode are shown in Figure 3-1 and Table 3-3, the supported bit widths are shown in Table 3-1, and the parameter list is shown in Table 3-2.

|              |           | Write Port |      |      |         |           |
|--------------|-----------|------------|------|------|---------|-----------|
|              |           | 16K*1      | 8K*2 | 4K*4 | 2K*9(8) | 1K*18(16) |
| Read<br>Port | 16K*1     | √          |      |      |         |           |
|              | 8K*2      |            | √    |      |         |           |
|              | 4K*4      |            |      | V    |         |           |
|              | 2K*9(8)   |            |      |      | √       |           |
|              | 1K*18(16) |            |      |      |         | $\sqrt{}$ |

Table 3-1 Asynchronous/Synchronous FIFO Mode Data Width List



Figure 3-1 DRM FIFO Mode Ports

Table 3-2 DRM\_FIFO Parameter List

| Parameter          | Description                           | Setting Value                      |
|--------------------|---------------------------------------|------------------------------------|
| GRS EN             | Global reset enable signal (Internal  | TRUE: Enable global reset;         |
| OKS_EN             | Chip)                                 | FALSE: Do not enable global reset. |
| DATA_WIDTH         | FIFO data width                       | 1, 2, 4, 8, 9, 16, 18              |
| ALMOST_FULL_OFFSET | When the FIFO is almost full and the  | DATA_WIDTH = 1: 1~8190             |
| ALMOS1_FULL_OFFSE1 | difference between the write and read | 2: 1~4094                          |

(UG030002, V1.2) 23 / 28



| Parameter           | Description                             | Setting Value                   |  |
|---------------------|-----------------------------------------|---------------------------------|--|
|                     | pointers is greater than or equal to    | 4: 1~2046                       |  |
|                     | ALMOST_FULL_OFFSET, the                 | 8/9: 1~1022                     |  |
|                     | ALMOST_FULL flag is set to 1.           | 16/18: 1~510                    |  |
|                     | When the FIFO is almost empty and       | DATA_WIDTH = 1: 1~8190          |  |
|                     | the difference between the read and     | 2: 1~4094                       |  |
| ALMOST_EMPTY_OFFSET | write pointers is less than or equal to | 4: 1~2046                       |  |
|                     | ALMOST_EMPTY_OFFSET, the                | 8/9: 1~1022                     |  |
|                     | ALMOST_EMPTY flag is set to 1.          | 16/18: 1~510                    |  |
| SYNC FIFO           | Asynchronous/Synchronous FIFO           | TRUE: Use synchronous FIFO;     |  |
| STNC_ITIO           | Selection                               | FALSE: Use asynchronous FIFO.   |  |
| USE EMPTY           | Enable read empty flog                  | 1: Read empty flag enabled;     |  |
| OSE_EMF11           | Enable read empty flag                  | 0: Read empty flag not enabled. |  |
| USE FULL            | Enable write full flag                  | 1: Write full flag enabled;     |  |
| USE_FOLL            | Enable write full mag                   | 0: Write full flag not enabled. |  |
| DO REG              | Output register enable                  | 1: Enabled;                     |  |
| DO_KEG              | Output register enable                  | 0: Not enabled.                 |  |

Table 3-3 DRM FIFO Mode Port Description

| Port Naming  | Direction | Description            |
|--------------|-----------|------------------------|
| ORCE         | Input     | Output register enable |
| RST          | Input     | Reset                  |
| WCLK         | Input     | Write clock            |
| WCE          | Input     | Write enable           |
| RCLK         | Input     | Read clock             |
| RCE          | Input     | Read enable            |
| DI           | Input     | Data input bus         |
| WCNT         | Output    | Write pointer          |
| RCNT         | Output    | Read pointer           |
| DO           | Output    | Data output bus        |
| ALMOST_EMPTY | Output    | Almost empty signal    |
| ALMOST_FULL  | Output    | Almost full signal     |
| EMPTY        | Output    | Empty signal           |
| FULL         | Output    | Full signal            |

(UG030002, V1.2) 24 / 28



#### 3.2 DRM\_FIFO Read/Write Timing

#### 3.2.1 Write Timing to Empty FIFO

The EMPTY signal indicates the FIFO is empty. When WCE is active and data is successfully written, in synchronous FIFO, the EMPTY signal is cleared after one RCLK clock cycle; in asynchronous FIFO, the EMPTY signal is cleared after one to two RCLK clock cycles. When WCE remains active, the ALMOST\_EMPTY signal is cleared with a delay based on the configuration of ALMOST\_EMPTY OFFSET. The write timing to empty asynchronous FIFO is shown in Figure 3-2:



Figure 3-2 Writing Timing to Empty Asynchronous FIFO

#### 3.2.2 Write Timing to Almost Full FIFO

When the FIFO is almost full, ALMOST\_FULL is set in advance, according to the configuration of ALMOST\_FULL\_OFFSET. When the FULL signal of FIFO is set to 1, the write pointer will no longer be incremented. Write timing to almost full FIFO is shown in Figure 3-3:



Figure 3-3 Write Timing to Almost Full FIFO

#### 3.2.3 Read Timing from Full FIFO

The FULL signal indicates the FIFO is full. After data is read out when RCE is active, the FULL

(UG030002, V1.2) 25 / 28

signal is cleared within one to two WCLK clock cycles. When RCE remains active, the ALMOST\_FULL signal is cleared with a delay based on the configuration of ALMOST\_FULL\_OFFSET. Read timing from full asynchronous FIFO is shown in Figure 3-4:



Figure 3-4 Read Timing from Full Asynchronous FIFO

#### 3.2.4 Read Timing from Almost Empty FIFO

When the FIFO is almost empty, ALMOST\_EMPTY is set in advance, based on the configuration of ALMOST\_EMPTY\_OFFSET. When the EMPTY signal of FIFO is set to 1, the read pointer will no longer be incremented. Read timing from almost empty FIFO is shown in Figure 3-5:



Figure 3-5 Read Timing from Almost Empty FIFO

#### 3.3 DRM FIFO Cascade Expansion

#### 3.3.1 Recommended Method for Depth Expansion

Depth expansion can be achieved by cascading N FIFOs: if the frequency of WCLK is higher than that of the RCLK, then INTCLK = WCLK; if the frequency of WCLK is less than or equal to that

(UG030002, V1.2) 26 / 28



of the RCLK, then INTCLK = RCLK. The ALMOST\_EMPTY signal is generated by the last FIFO, and the ALMOST\_FULL signal is generated by the first FIFO. See Figure 3-6 for the recommended method for depth expansions.



Figure 3-6 Recommended Method for Depth Expansion

Note: The "~FULL" in the diagram indicates the inverse of the FIFO FULL signal.

#### 3.3.2 Recommended Method for Width Expansion

Width expansion can be achieved through parallel FIFOs, see Figure 3-7 for the recommended method for width expansion.



Figure 3-7 Recommended Method for Width Expansion

(UG030002, V1.2) 27 / 28



## **Disclaimer**

#### **Copyright Notice**

This document is copyrighted by Shenzhen Pango Microsystems Co., Ltd., and all rights are reserved. Without prior written approval, no company or individual may disclose, reproduce, or otherwise make available any part of this document to any third party. Non-compliance will result in the Company initiating legal proceedings.

#### **Disclaimer**

- 1. This document only provides information in stages and may be updated at any time based on the actual situation of the products without further notice. The Company assumes no legal responsibility for any direct or indirect losses caused by improper use of this document.
- 2. This document is provided "as is" without any warranties, including but not limited to warranties of merchantability, fitness for a particular purpose, non-infringement, or any other warranties mentioned in proposals, specifications, or samples. This document does not grant any explicit or implied intellectual property usage license, whether by estoppel or otherwise.
- 3. The Company reserves the right to modify any documents related to its series products at any time without prior notice.

(UG030002, V1.2) 28 / 28